Proyecto Final - Circuitos Digitales I

## MDIO

Cantidad de personas:

Fecha de entrega: 1 Julio a las 11:59 pm.

## | Parte 1. | Generador de transacciones MDIO

1. Diseñe un generador de transacciones de acuerdo a la clausula 22 del estándar IEEE 802.3, las secciones 22.2.2.13 (MII) y
22.2.2.14 (MDIO)

Imagen del generador de transacciones.



## SENALES

- 1. CIK (NO ESTA EN LA FIGURA) = Entrada que llega di generador de transacciones desde el CPU con una frecuencia determinada.
- 2. MDC = SALIDA de reloj para el MDIO, que deberá tener una trewencia de la <u>mitad</u> de la <u>trewencia</u> de la entrada del CEK. Se debe generar MDC con la trewencia correcta para cualquier valor de la frecuencia de entrada de CLK.
- 3. RESET (NO ESTA EN LA FIGURA) = Entrado de reinicio del generador. Si RESET =1 el generador funciona normalmente. De la contrario vuelle

- al estado inicial y todas las salidas toman el valor de cero.
- 4. MDIO\_START = PULSO de un ciclo de reloj. Indical al generador que se ha largado un valor en la entrada T-DATA y que se debe iniciar la transmisión de los datos a través de lo salido serial. (MDIO-OUT)
- 5. MDIO-OUT = <u>Salida</u> <u>serial</u> <u>cuando</u> se habilita MDIO-START = 1, se envia a través de la salida MDIO-OUT los bits que se observan en la entrada T\_DATA, emperando por el bit más significativo y hasta completar los 32 bits.
- 6. MDIO\_OE = Habilitación de MDIO-OUT. Esta salida debe detectar si la transacción de esantomo, metho es de lectura o escritura. Si la transacción es de escritura, debe permanecer en alto durante 32 ciolos de la transacción y ponerse en bajo cuando termine. En una transacción de lectura, debe permanecer en alto durante las primeros 16 ciclos de la transacción, y ponerse en bajo durante los siguientes 16 ciclos, mientros se
- 7. MDIO\_IN = Entrada serie. Durante una operación de lectura, se debe leer el valor de esta entrada durante los últimos 16 ciclos de la transacción MDIO y escribirlos en la salida RD\_DATA.

recibe el dato en MDIO\_IN. Esta señal debe quedar en cero.

8. T\_DATA [31:0] = Entrada paralela. Cuando se habilita IMDIO-START en el siguiente ciclo de reloj se transmite el bit T\_DATA [31] por la salida MDIO-eut y durante los siguientes ciclos se transmite un bit por ciclo hasta completar el envio de la

palobra completa.

9. RD\_DATA [18:0] = Esta salida debe producir les lb bits que se reciben desde el PHY durante una transacción de lectura recibida en MDia\_IN. El valor de RD\_DATA solo es válido cuando DATA\_RDY es igual a 1.

- 10. DATA RDY = Salida se pone en 1 cuando se ha completado la recepción de una palabra serial completa durante una transacción de lectura.
- 2. Escriba un código de en verilog del generador de transaccione moio, para esto debe requizar también un tester y un testbench. En archivos separados.
  - 2.a El tester debe cubrir las siguientes pruebas

    → ESCRITURA
    - LECTURA
    - CONDICIÓN DE RESET.